<template>
  <div class="p-2">
    <!--查询区域-->
    <div class="jeecg-basic-table-form-container">

      <a-tabs v-model:activeKey="waybillStatus" @change="changeStatus" style="background: white"
              type="card">
        <a-tab-pane key="0" tab="全部"/>
        <a-tab-pane key="1" tab="待接单"/>
        <a-tab-pane key="2" tab="待装货"/>
        <a-tab-pane key="3" tab="待发车"/>
        <a-tab-pane key="4" tab="待签收"/>
        <a-tab-pane key="5" tab="待评价"/>
        <a-tab-pane key="6" tab="已完成"/>
        <a-tab-pane key="7" tab="已过期"/>
      </a-tabs>
      <a-form ref="formRef" @keyup.enter.native="searchQuery" :model="queryParam"
              :label-col="labelCol" :wrapper-col="wrapperCol">
        <a-row :gutter="24">
          <!--          <a-col :lg="6">
                      <a-form-item name="userId">
                        <template #label><span title="创建人">创建人</span></template>
                        <j-search-select placeholder="请选择创建人" v-model:value="queryParam.userId" dict="sys_user,realname,id" />
                      </a-form-item>
                    </a-col>-->
          <a-col :lg="6">
            <a-form-item name="waybillNo">
              <template #label><span title="运单号">运单号</span></template>
              <a-input placeholder="请输入运单号" v-model:value="queryParam.waybillNo"></a-input>
            </a-form-item>
          </a-col>
          <a-col :lg="6">
            <a-form-item>
              <template #label><span title="提货时间">提货时间</span></template>
              <div style="display: flex">
                <a-form-item name="deliveryTime_begin" style="margin-bottom: 0;">
                  <a-date-picker showTime value-format="YYYY-MM-DD HH:mm:ss"
                                 placeholder="请选择开始时间"
                                 v-model:value="queryParam.deliveryTime_begin"
                                 class="query-group-cust"/>
                </a-form-item>
                <span class="query-group-split-cust">~</span>
                <a-form-item name="deliveryTime_end" style="margin-bottom: 0;">
                  <a-date-picker showTime value-format="YYYY-MM-DD HH:mm:ss"
                                 placeholder="请选择结束时间"
                                 v-model:value="queryParam.deliveryTime_end"
                                 class="query-group-cust"/>
                </a-form-item>
              </div>
            </a-form-item>
          </a-col>
          <template v-if="toggleSearchStatus">
            <a-col :lg="6">
              <a-form-item name="shipperName">
                <template #label><span title="发货人姓名">发货人姓</span></template>
                <a-input placeholder="请输入发货人姓名"
                         v-model:value="queryParam.shipperName"></a-input>
              </a-form-item>
            </a-col>
            <a-col :lg="6">
              <a-form-item name="shipperPhone">
                <template #label><span title="发货人电话">发货人电</span></template>
                <a-input placeholder="请输入发货人电话"
                         v-model:value="queryParam.shipperPhone"></a-input>
              </a-form-item>
            </a-col>
            <a-col :lg="6">
              <a-form-item name="shipperIdNum">
                <template #label><span title="发货人证件号">发货人证</span></template>
                <a-input placeholder="请输入发货人证件号"
                         v-model:value="queryParam.shipperIdNum"></a-input>
              </a-form-item>
            </a-col>
            <a-col :lg="6">
              <a-form-item name="shipperAreaCode">
                <template #label><span title="发货人地区编码">发货人地</span></template>
                <j-area-select v-model:value="queryParam.shipperAreaCode"
                               placeholder="请选择发货人地区编码"/>
              </a-form-item>
            </a-col>
            <a-col :lg="6">
              <a-form-item name="consignerName">
                <template #label><span title="收货方姓名">收货方姓</span></template>
                <a-input placeholder="请输入收货方姓名"
                         v-model:value="queryParam.consignerName"></a-input>
              </a-form-item>
            </a-col>
            <a-col :lg="6">
              <a-form-item name="consignerPhone">
                <template #label><span title="收货方电话">收货方电</span></template>
                <a-input placeholder="请输入收货方电话"
                         v-model:value="queryParam.consignerPhone"></a-input>
              </a-form-item>
            </a-col>
            <a-col :lg="6">
              <a-form-item name="consignerIdNum">
                <template #label><span title="收件方证件号">收件方证</span></template>
                <a-input placeholder="请输入收件方证件号"
                         v-model:value="queryParam.consignerIdNum"></a-input>
              </a-form-item>
            </a-col>
            <a-col :lg="6">
              <a-form-item name="consignerAreaCode">
                <template #label><span title="收货方地区编码">收货方地</span></template>
                <j-area-select v-model:value="queryParam.consignerAreaCode"
                               placeholder="请选择收货方地区编码"/>
              </a-form-item>
            </a-col>
            <a-col :lg="6">
              <a-form-item name="cargoName">
                <template #label><span title="货物名称">货物名称</span></template>
                <a-input placeholder="请输入货物名称"
                         v-model:value="queryParam.cargoName"></a-input>
              </a-form-item>
            </a-col>
            <a-col :lg="6">
              <a-form-item name="izInvoicingFee">
                <template #label><span title="是否收取代收款">是否收取</span></template>
                <j-switch placeholder="请选择是否收取代收款"
                          v-model:value="queryParam.izInvoicingFee" :options="[1,0]" query/>
              </a-form-item>
            </a-col>
            <a-col :lg="6">
              <a-form-item name="invoicingOrderNum">
                <template #label><span title="代收款订单号">代收款订</span></template>
                <a-input placeholder="请输入代收款订单号"
                         v-model:value="queryParam.invoicingOrderNum"></a-input>
              </a-form-item>
            </a-col>
            <a-col :lg="6">
              <a-form-item name="invoicingRealPayMode">
                <template #label><span title="实际代收款支付方式">实际代收</span></template>
                <j-dict-select-tag placeholder="请选择实际代收款支付方式"
                                   v-model:value="queryParam.invoicingRealPayMode"
                                   dictCode="pay_mode"/>
              </a-form-item>
            </a-col>
            <a-col :lg="6">
              <a-form-item name="settleFreightStatus">
                <template #label><span title="结算运费状态">结算运费</span></template>
                <j-switch placeholder="请选择结算运费状态"
                          v-model:value="queryParam.settleFreightStatus" :options="[1,0]" query/>
              </a-form-item>
            </a-col>
            <a-col :lg="6">
              <a-form-item name="settleFreightTime">
                <template #label><span title="运费结算时间">运费结算</span></template>
                <a-date-picker showTime valueFormat="YYYY-MM-DD HH:mm:ss"
                               placeholder="请选择运费结算时间"
                               v-model:value="queryParam.settleFreightTime"/>
              </a-form-item>
            </a-col>
            <a-col :lg="6">
              <a-form-item name="driverUserId">
                <template #label><span title="接单用户">接单用户</span></template>
                <j-search-select placeholder="请选择接单用户"
                                 v-model:value="queryParam.driverUserId"
                                 dict="sys_user,realname,id"/>
              </a-form-item>
            </a-col>
            <a-col :lg="6">
              <a-form-item name="driverVehicleNo">
                <template #label><span title="司机车牌号">司机车牌</span></template>
                <a-input placeholder="请输入司机车牌号"
                         v-model:value="queryParam.driverVehicleNo"></a-input>
              </a-form-item>
            </a-col>
            <a-col :lg="6">
              <a-form-item name="driverPhone">
                <template #label><span title="司机电话">司机电话</span></template>
                <a-input placeholder="请输入司机电话"
                         v-model:value="queryParam.driverPhone"></a-input>
              </a-form-item>
            </a-col>
            <a-col :lg="6">
              <a-form-item name="driverName">
                <template #label><span title="司机姓名">司机姓名</span></template>
                <a-input placeholder="请输入司机姓名"
                         v-model:value="queryParam.driverName"></a-input>
              </a-form-item>
            </a-col>
            <a-col :lg="6">
              <a-form-item name="driverBankId">
                <template #label><span title="司机银行卡">司机银行</span></template>
                <a-input placeholder="请输入司机银行卡"
                         v-model:value="queryParam.driverBankId"></a-input>
              </a-form-item>
            </a-col>
            <a-col :lg="6">
              <a-form-item name="driverBankHolder">
                <template #label><span title="司机银行开户名">司机银行</span></template>
                <a-input placeholder="请输入司机银行开户名"
                         v-model:value="queryParam.driverBankHolder"></a-input>
              </a-form-item>
            </a-col>
            <a-col :lg="6">
              <a-form-item name="driverBankCardNo">
                <template #label><span title="司机银行卡号">司机银行</span></template>
                <a-input placeholder="请输入司机银行卡号"
                         v-model:value="queryParam.driverBankCardNo"></a-input>
              </a-form-item>
            </a-col>
            <a-col :lg="6">
              <a-form-item name="driverBankName">
                <template #label><span title="司机开户银行">司机开户</span></template>
                <a-input placeholder="请输入司机开户银行"
                         v-model:value="queryParam.driverBankName"></a-input>
              </a-form-item>
            </a-col>
            <a-col :lg="6">
              <a-form-item name="waybillStatus">
                <template #label><span title="订单状态">订单状态</span></template>
                <j-dict-select-tag placeholder="请选择订单状态"
                                   v-model:value="queryParam.waybillStatus"
                                   dictCode="waybill_status"/>
              </a-form-item>
            </a-col>
          </template>
          <a-col :xl="6" :lg="7" :md="8" :sm="24">
            <span style="float: left; overflow: hidden" class="table-page-search-submitButtons">
              <a-col :lg="6">
                <a-button type="primary" preIcon="ant-design:search-outlined" @click="searchQuery">查询</a-button>
                <a-button type="primary" preIcon="ant-design:reload-outlined" @click="searchReset"
                          style="margin-left: 8px">重置</a-button>
                <a @click="toggleSearchStatus = !toggleSearchStatus" style="margin-left: 8px">
                  {{ toggleSearchStatus ? '收起' : '展开' }}
                  <Icon
                    :icon="toggleSearchStatus ? 'ant-design:up-outlined' : 'ant-design:down-outlined'"/>
                </a>
              </a-col>
            </span>
          </a-col>
        </a-row>
      </a-form>
    </div>
    <!--引用表格-->
    <BasicTable @register="registerTable" :rowSelection="rowSelection">
      <!--插槽:table标题-->
      <template #tableTitle>
        <!--        <a-button type="primary" @click="handleAdd" preIcon="ant-design:plus-outlined"> 新增</a-button>
                <a-button  type="primary" preIcon="ant-design:export-outlined" @click="onExportXls"> 导出</a-button>
                <j-upload-button  type="primary" preIcon="ant-design:import-outlined" @click="onImportXls">导入</j-upload-button>-->
        <a-dropdown v-if="selectedRowKeys.length > 0">
          <template #overlay>
            <a-menu>
              <a-menu-item key="1" @click="batchHandleDelete">
                <Icon icon="ant-design:delete-outlined"></Icon>
                删除
              </a-menu-item>
            </a-menu>
          </template>
          <a-button>批量操作
            <Icon icon="mdi:chevron-down"></Icon>
          </a-button>
        </a-dropdown>
        <!-- 高级查询 -->
        <super-query :config="superQueryConfig" @search="handleSuperQuery"/>
      </template>
      <!--操作栏-->
      <template #action="{ record }">
        <TableAction :actions="getTableAction(record)"
                     :dropDownActions="getDropDownAction(record)"/>
      </template>
      <template v-slot:bodyCell="{ column, record, index, text }">
        <template v-if="column.dataIndex==='shipperAreaCode'">
          <!--省市区字段回显插槽-->
          {{ getAreaTextByCode(text) }}
        </template>
        <template v-if="column.dataIndex==='consignerAreaCode'">
          <!--省市区字段回显插槽-->
          {{ getAreaTextByCode(text) }}
        </template>
      </template>
    </BasicTable>
    <!-- 表单区域 -->
    <WlhyWaybillModal ref="registerModal" @success="handleSuccess"></WlhyWaybillModal>
  </div>
</template>

<script lang="ts" name="waybill-wlhyWaybill" setup>
import {ref, reactive} from 'vue';
import {BasicTable, useTable, TableAction} from '/@/components/Table';
import {useListPage} from '/@/hooks/system/useListPage';
import {columns, superQuerySchema} from './WlhyWaybill.data';
import {
  list,
  deleteOne,
  batchDelete,
  getImportUrl,
  getExportUrl,
  loadCargo
} from './WlhyWaybill.api';
import {downloadFile} from '/@/utils/common/renderUtils';
import WlhyWaybillModal from './components/WlhyWaybillModal.vue'
import {useUserStore} from '/@/store/modules/user';
import JDictSelectTag from '/@/components/Form/src/jeecg/components/JDictSelectTag.vue';
import JSwitch from '/@/components/Form/src/jeecg/components/JSwitch.vue';
import JSearchSelect from '/@/components/Form/src/jeecg/components/JSearchSelect.vue';
import JAreaSelect from '/@/components/Form/src/jeecg/components/JAreaSelect.vue';
import {getAreaTextByCode} from '/@/components/Form/src/utils/Area';

const userStore = useUserStore();
const userInfo = useUserStore().getUserInfo

const waybillStatus = ref("0");
const formRef = ref();
const queryParam = reactive<any>({status: "1", userId: userInfo.id});
const toggleSearchStatus = ref<boolean>(false);
const registerModal = ref();

//注册table数据
const {prefixCls, tableContext, onExportXls, onImportXls} = useListPage({
  tableProps: {
    title: '订单表',
    api: list,
    columns,
    canResize: false,
    useSearchForm: false,
    actionColumn: {
      width: 120,
      fixed: 'right',
    },
    beforeFetch: (params) => {
      return Object.assign(params, queryParam);
    },
  },
  exportConfig: {
    name: "订单表",
    url: getExportUrl,
    params: queryParam,
  },
  importConfig: {
    url: getImportUrl,
    success: handleSuccess
  },
});
const [registerTable, {
  reload,
  collapseAll,
  updateTableDataRecord,
  findTableDataRecord,
  getDataSource
}, {rowSelection, selectedRowKeys}] = tableContext;
const labelCol = reactive({
  xs: 24,
  sm: 4,
  xl: 6,
  xxl: 4
});
const wrapperCol = reactive({
  xs: 24,
  sm: 20,
});

// 高级查询配置
const superQueryConfig = reactive(superQuerySchema);


const changeStatus = (e) => {
  if (e == 0) {
     Object.keys(queryParam).forEach(key => {
      delete queryParam[key];
    });
    Object.assign(queryParam, {status: '1'})
  } else {
    Object.assign(queryParam, {status: '1', waybillStatus: e})
  }
  searchQuery();
}

/**
 * 高级查询事件
 */
function handleSuperQuery(params) {
  Object.keys(params).map((k) => {
    queryParam[k] = params[k];
  });
  searchQuery();
}

/**
 * 新增事件
 */
function handleAdd() {
  registerModal.value.disableSubmit = false;
  registerModal.value.add();
}

/**
 * 编辑事件
 */
function handleEdit(record: Recordable) {
  registerModal.value.disableSubmit = false;
  registerModal.value.edit(record);
}

/**
 * 详情
 */
function handleDetail(record: Recordable) {
  registerModal.value.disableSubmit = true;
  registerModal.value.edit(record);
}

/**
 * 删除事件
 */
async function handleDelete(record) {
  await deleteOne({id: record.id}, handleSuccess);
}

/**
 * 批量删除事件
 */
async function batchHandleDelete() {
  await batchDelete({ids: selectedRowKeys.value}, handleSuccess);
}

/**
 * 成功回调
 */
function handleSuccess() {
  (selectedRowKeys.value = []) && reload();
}

/**
 * 操作栏
 */
function getTableAction(record) {
  return [
    {
      label: '编辑',
      onClick: handleEdit.bind(null, record),
    },
  ];
}

/**
 * 下拉操作栏
 */
function getDropDownAction(record) {
  let enoughArr = [
    {
      label: '详情',
      onClick: handleDetail.bind(null, record),
    }, {
      label: '删除',
      popConfirm: {
        title: '是否确认删除',
        confirm: handleDelete.bind(null, record),
        placement: 'topLeft',
      }
    }
  ];
  if (waybillStatus.value == '2') {
    enoughArr.push({
      label: '装货',
      onClick: ()=>{
        loadCargo({waybillId: record.id}, handleSuccess)
      },
    },)
  }
  return enoughArr
}

/**
 * 查询
 */
function searchQuery() {
  reload();
}

/**
 * 重置
 */
function searchReset() {
  formRef.value.resetFields();
  selectedRowKeys.value = [];
  //刷新数据
  reload();
}


/**
 * form点击事件(以逗号分割)
 * @param key
 * @param value
 */
function handleFormJoinChange(key, value) {
  queryParam[key] = value.join(',');
}


</script>

<style lang="less" scoped>
.jeecg-basic-table-form-container {
  padding: 0;

  .table-page-search-submitButtons {
    display: block;
    margin-bottom: 24px;
    white-space: nowrap;
  }

  .query-group-cust {
    min-width: 100px !important;
  }

  .query-group-split-cust {
    width: 30px;
    display: inline-block;
    text-align: center
  }
}
</style>
